

ここでは、付属 FPGA 基板に実装されている FPGA 「Spartan -3Eファミリ」 の特徴について解説する。 Spartan-3Eファミリは、論理ブロックや I/O ブロックのほかに、メモリや乗算器、クロック管理などの専用機能ブロックを持つ。 (編集部)

米国 Xilinx 社の「Spartan-3E ファミリ」は,大量生産される民生機器でも使われている低コスト FPGA(field programmable gate array)です.ここでは,Spartan-3E の位置付けと,想定される使用方法について簡単に説明します.また,Spartan-3E に搭載されている各種機能を解説します.

# 1. Spartan-3Eファミリの 位置付けを知る

Xilinx 社では,90nm プロセス技術によって製造される低コスト FPGA 製品群を総称して「Spartan-3 Generation FPGA」と呼んでいます.この製品群の中におけるSpatran-

3E の位置付けを図1に示します. Spartan-3E は,ユーザ I/O の数を基準にして比べると,より論理プロックを多く搭載する FPGA ファミリであることが分かります.

Spartan-3E ファミリの詳細を表1に示します. 付属 FPGA



図1 Spartan-3 Generation **における** Spartan-3E **の位置付け** 横軸にユーザI/Oの数,縦軸に論理プロック数を示している。Spartan-3E は,ユーザI/Oの数を基準にして比べると,より論理プロックを多く搭載するファミリである。

### 表1 Spartan-3E ファミリの概要

|           | システム・ | ロジック・  | CLBアレイ |      |       | 分散    | Block |     |       | 最大   | 最大   |                               |
|-----------|-------|--------|--------|------|-------|-------|-------|-----|-------|------|------|-------------------------------|
| 型名        | ゲート   | セル     | (1CLB  | = 4ス |       |       | RAM   | 乗算器 | DCM 数 | ユーザ  | 差動   | パッケージ                         |
|           | 9-6   | L/V    | ロウ     | カラム  | 総数    | (ビット) | (ビット) |     |       | I/O数 | I/O数 |                               |
| XC3S100E  | 10万   | 2,160  | 22     | 16   | 240   | 15K   | 72K   | 4   | 2     | 108  | 40   | VQ100 , TQ144                 |
| XC3S250E  | 25万   | 5,508  | 34     | 26   | 612   | 38K   | 216K  | 12  | 4     | 172  | 68   | VQ100 , TQ144 , PQ208 , FT256 |
| XC3S500E  | 50万   | 10,476 | 46     | 34   | 1,164 | 73K   | 360K  | 20  | 4     | 232  | 92   | CP132 , PQ208 , FT256 , FG320 |
| XC3S1200E | 120万  | 19,512 | 60     | 46   | 2,168 | 136K  | 504K  | 28  | 8     | 304  | 124  | FT256 , FG320 , FG400         |
| XC3S1600E | 160万  | 33,192 | 76     | 58   | 3,688 | 231K  | 648K  | 36  | 8     | 376  | 156  | FG320 , FG400 , FG484         |

XC3S250E-VQ100のI/O数は66

KeyWord

FPGA, Spartan-3E, XC3S250E, クロック管理, DCM, メモリ, 乗算器, コンフィグレーション, DDR

基板に搭載されている XC3S250E-VQ100 は,66本のユーザI/O しかありませんが,25万ゲート相当の論理ブロックを搭載しています.

このような特徴を持った FPGA は、例えば制御装置への応用が考えられます・監視する信号は数本しかなくても、その状態に合わせて複雑な処理を行う制御装置では、ピン数に対して回路規模が大きくなります・

また,別の応用先としては,ディジタル信号処理装置が 挙げられます.無線アクセス装置で使われるディジタル・ アップダウン・コンバータなどの演算処理には,低コスト で演算機能を豊富に持つ FPGA は魅力的に感じます.

## 2. Spartan-3Eの基本機能を知る

Spartan-3Eに搭載されている主な機能について説明します. 既に Spartan-3の使用経験がある方のために, Spartan-3との違いについても触れます.

Spartan-3E は,図2に示すような機能ブロックから構成されています.

- 論理ブロック( CLB: configurable logic block )
- I/O ブロック( IOB )
- クロック管理ブロック( DCM, BUFG)

- メモリ・ブロック(BRAM)
- 乗算器ブロック(MULT)
- コンフィグレーション回路

### ● 論理ブロック(CLB)

FPGA という名前は、CLB の構造に由来すると言っても 過言ではありません、論理回路を自由に構成するための基 本的なしくみです、

CLBは、順序回路や組み合わせ回路を構成するための論理ブロックです、四つのスライス(SLICE)から構成されています(図3).

各スライスは隣接するスイッチ・マトリックスを介して内部リソースを接続します.CLBの内部ではスライスは左右2個ずつに区分けされ,SLICEMとSLICELと呼ばれています.

2種類のスライスは,図4に示すように,それぞれ二つの4入力ルックアップ・テーブル(LUT: look-up table)と二つのフリップフロップ,マルチプレクサ(MUX)などで構成されています.SLICELのルックアップ・テーブルは組み合わせ回路のみを実現できます(LUT4).SLICEMではさらに,メモリ(RAM16;分散型RAM)や16ビット・シフト・レジスタ(SRL16)を実現できます.



図2 XC3S250E の構造

論理プロック( CLB : configurable logic block ) , I/O プロック( IOB ) , クロック管理プロック( DCM , BUFG ) , メモリ・プロック( BRAM ) , 乗算器プロック( MULT ) , コンフィグレーション回路から構成されている .



## 図3 CLB **の構造**

一つの CLB は , 四つのスライス( Slice )で構成される . 左側のスライスは , 論理回路以外の機能としても使用できる .

FPGAでは、ルックアップ・テーブルを使って組み合わせ回路を実現します。ANDゲートやORゲートなどのゲート素子を使って論理を構成するわけではありません。ルックアップ・テーブルはメモリ・セルで構成されています。このメモリ・セルに所望の入出力論理値を書き込むことによって論理ゲートと同等の機能を果たします。

例えば2入力 AND を考えてみます( 図5 ). 真理値表の入力値をメモリのアドレス,出力値をメモリのデータに置き換えれば,ゲートと同じ論理がルックアップ・テーブルで実現できることが分かります.

ゲートをメモリ・セルで置き換えていることが分かれば、ルックアップ・テーブルで分散型RAMやシフト・レジスタを実現できることも納得できると思います.一つの4人力ルックアップ・テーブルでは、16ビットのメモリを構成できます.また16ビットまでのシフト・レジスタを構成できます.ルックアップ・テーブルを複数接続することによって、より大きなメモリや多段のシフト・レジスタを構成することもできます.

## ● I/O ブロック

I/O ブロックは, 論理ブロックとI/O ピンとのインターフェースを行います. 主として図6の機能を持ちます.

- ●入力/出力/3ステート・レジスタ
- プログラマブル入力/出力バッファ
- プログラマブル遅延





(b) SLICEL

#### 図4 SLICEM とSLICEL

SLICEL のルックアップ・テーブルは組み合わせ回路のみを実現できる(LUT4). SLICEMではさらに,メモリ(RAM16;分散型RAM)や16ビット・シフト・レジスタ(SRL16)を実現できる.



図5 ルックアップ・テーブルによる組み合わせ回路の実現

真理値表の入力値をメモリのアドレス,出力値をメモリのデータに置き換えれば,ゲートと同じ論理がルックアップ・テーブルで実現できる.

## (1)入力/出力/3ステート・レジスタ

出力信号や入力信号,3ステート信号に対してそれぞれ 搭載するフリップフロップです.I/Oピンの位置によらず, 入力パッドからフリップフロップまでの遅延値や,フリッ プフロップから出力パッドまでの遅延値が一定に保たれて います.バス・データの遅延差(スキュー)を抑えるために

## 役立ちます.

また , フリップフロップは , 入力 , 出力 , 3ステートそれぞれペアで搭載されていて , DDR( double data rate )インターフェースを実現できます . 図7のように , IOB-CLK内部にある二つのフリップフロップの入力信号をそれぞれ"L", "H"に固定すれば , IOB-DATAのデータ線と同相の



**図**6 I/O **ブロックの構造** 

入力/出力/3ステート・レジスタ , プログラマブル 入力/出力バッファ , プログラマブル遅延などで構 成されている .





図7 I/O プロックによる DDR インターフェースの実現例

IOB-CLK 内部にある二つのフリップフロップの入力信号をそれぞれ" L " , " H "レベルに固定すれば , IOB-DATA のデータ線と同相のエッジを持つクロック出力を得ることもできる.

エッジを持つクロック出力を得ることもできます.

## (2)プログラマブル入力/出力パッファ

入出力バッファは,LVTTLやLVCMOSなどの13種類のシングル・エンドI/O規格と,LVDSやLVPECLなどの9種類の差動I/O規格に対応しています(表2).LVTTLとLVCMOSでは,出力ドライブ電流を選択できます.

## (3)プログラマブル遅延

入力信号に対してデータを0~約5.8nsまで段階的に遅延させるプログラマブル遅延機能を持ちます.

図8のように,遅延ブロックは初段遅延部と後段遅延部に分かれています.初段遅延部で比較的大きな遅延を設定し,後段遅延部で微調整を行うしくみです.

遅延時間の設定は FPGA 開発ツールを使って行います. 遅延させたい値を指定することによって, どの遅延パスを 使うかをツールが自動的に決定するので,難しい設定は必 要ありません.

また後段の微調整は,同期入力(I/Oブロックの入力フリップフロップを使用するルート)に対しては約500psごと,非同期入力(I/Oブロックの入力フリップフロップを使用しないルート)に対しては約250psごとの調整ができます.

この機能により、従来はプリント基板上で合わせ込む必要のあった遅延時間の調整を、FPGAの内部でできるようになります。また、期待通りのタイミングで信号が入力されてこなかったような場合にも、FPGAの内部でタイミングを調整できるようになります。

すべての1/0は,複数の1/0バンクと呼ばれるグループ

#### 表2 Spartan-3E が対応するI/O 規格

|               | I/O規格                                                  | $V_{CCO}(V)$ | クラスなど                                    |
|---------------|--------------------------------------------------------|--------------|------------------------------------------|
|               |                                                        | 1.2          | 2mA ,                                    |
| シングル・エンド      |                                                        | 1.5          | 2mA , 4mA , 6mA ,                        |
|               | LVCMOS                                                 | 1.8          | 2mA , 4mA ,<br>6mA , 8mA ,               |
|               | (low voltage CMOS)                                     | 2.5          | 2mA , 4mA , 6mA ,<br>8mA , 12mA ,        |
|               |                                                        | 3.3          | 2mA , 4mA , 6mA ,<br>8mA , 12mA , 16mA , |
| エンド           | LVTTL<br>(low voltage-transistor<br>-transistor-logic) | 3.3          | 8mA , 12mA , 16mA ,                      |
|               | PCI                                                    |              | 33MHz                                    |
|               | ( peripheral component interconnect )                  | 3.0          | 66MHz                                    |
|               | PCI-X                                                  | 3.0          | -                                        |
| および差動シングル・エンド | HSTL<br>( high speed<br>transceiver logic )            | 1.8          |                                          |
| 動工            | SSTL                                                   | 1.8          |                                          |
| ンド            | ( stub series terminated logic )                       | 2.5          |                                          |
|               | LVDS                                                   |              | Standard                                 |
|               | (low voltage                                           | 2.5          | Bus                                      |
| 差             | differential signaling )                               |              | mini                                     |
|               | LVPECL( low voltage                                    | 2.5          |                                          |
| 動             | positive emitter coupled logic )                       | 2.5          | -                                        |
| <i>≨IJ</i>    | RSDS( reduced<br>swing differential<br>signaling )     | 2.5          | -                                        |

に分けられています. Spartan-3E は四つのI/Oバンクを持ちます(図9). I/Oバンクは,同一のI/O電源電圧が適用されるグループと考えれば分かりやすいでしょう.

## ● クロック管理ブロック(DCM, BUFG)

FPGA の性能を引き出す上で, FPGA が持つクロック・リソースの構成をきちんと理解することが重要です.逆に,



図8 プログラマブル遅延エレメント

初段遅延部と後段遅延部に分かれている.初段遅延部で比較的大きな遅延を設定し,後段遅延部で微調整を行う.



図9 1/0 バンク

Spartan-3E は四つのI/Oバンクを持つ. I/OバンクごとにI/O電圧を設定できる. クロック・リソースの使い方を誤ると,さまざまな副作用 により回路の動作が不安定になるので,しっかりと理解し て使用してください.

Spartan-3Eには,クロック関連のリソースとして,クロック管理機能のDCM(digital clock manager),クロック・バッファ(BUFG),グローバル・クロック・ネットワークがあります。

#### (1)DCM

DCM はクロックの位相を管理したり, さまざまな周波数のクロックを生成したりするモジュールです. 本誌付属の XC3S250E は, 四つの DCM を持ちます. 図10に DCM のブロック図を示します.

DCM の中心的な機能は DLL( delay locked loop )です.フィードバック・ループからの遅延情報をもとに,クロック線の伝播遅延がゼロになるように,内部の遅延タップを利用してスキューを調整します.また,DLL の出力には入力クロックに対して同位相で出力する CLK0,入力クロックに対して 90 単位で位相を調整して出力する CLK90, CLK180, CLK270,入力クロックに対して2倍の周波数を出力する CLK2X, CLK2X180(180 位相シフト),分周クロックを出力する CLKDV があります.

DFS(ディジタル周波数合成)ブロックは,入力したクロックに対して,

出力クロック:  $M/D \times$ 入力クロック ( $M = 2 \sim 32$ の整数,  $D = 1 \sim 32$ の整数)

のクロックを合成することができます.1系統のクロック 入力から複数のクロック周波数を作成することができるの で,ボード上に搭載されるクロック発振器などの部品点数 の削減に役立ちます.

PS( 位相シフト )は , 入力クロック周期の1/256単位で位相調整を行います . この機能は , FPGA の入出力タイミングの見積もりが難しいインターフェースに使用できます . また , タイミング見積もりと実機との差分がでた場合に , この位相シフトによって差分を吸収するといった具合に , 実機検証工程におけるタイミング調整にも役立ちます .

# (2)クロック・バッファとグローバル・クロック・ネット ワーク

クロック・バッファは用途によって3種類の構成を取る ことができます.

- クロック入力を単純に内部フリップフロップに配るため に使用する低スキュー・バッファ BUFG
- クロックを止めるイネーブル信号を持ったクロック・ バッファ BUFGCE
- ●2系統のクロック入力をグリッジなしで切り替えるクロック・バッファ BUFGMUX

本誌付属の XC3S250E では,16 個のクロック・バッファを搭載しています.これらのバッファを介してグローバル・クロック・ネットワークへと信号を供給します.

図11のように, XC3S250E ではデバイスを4分割した各 エリアに対して8本ずつのグローバル・ネットワークが用 意されています。各クロック信号はこのグローバル・ネットワークを通じて, デバイス内部の各フリップフロップへ 供給されます。クロック信号を FPGA から入力する際に は, クロック専用ピン( GCLK, RHCLK, LHCLK)を使用



**図**10 DCM **のプロック図** 

DLL( delay locked loop ) , DFS( ディジタル周波数合成 ) , 位相シフト , ステータス論理の四つのブロックで構成される .

# 総力特集

# 付属FPGA基板を使った 回路設計チュートリアル Part3



図11 クロック・リソースとグローバル・ネットワーク

XC3S250E ではデバイスを4分割した各エリアに対して8本ずつのグローバル・ネットワークが用意されている.

します.なお,GCLKから入力したクロックは,デバイスの全体のエリアに対して供給することができますが,RHCLK,LHCLKから入力したクロックはFPGAの半分(左右で2分割)の領域へのみ供給されます.

Spartan-3Eでは,この上下左右に搭載されているクロック・バッファの性能が異なります.上下に搭載されているクロック・バッファの方が,左右に搭載されているクロック・バッファよりも高い周波数を駆動できます.230MHzを超えるクロック信号を使用する場合には,上下に搭載されているクロック・バッファを使用する必要があります.

## ● メモリ・ブロック

メモリ・ブロックは ,「Block RAM」と呼ばれています . 1個あたり 18K ビットで構成されています . 主にRAM(シングル・ポート/デュアル・ポート), ROM , FIFO , データ幅変換器などとして使用できます .

18K ビットのブロックで構成されていると言っても,常に18K ビット分の容量を自由に使えるわけではありません. それは構成可能なデータ幅と深さがあらかじめ決まっているからです(表3).

例えば,1,600 ワード×10 ビットのメモリが必要な場合を考えます。容量から言えば16K ビットあれば問題ないので,一つのブロックで実現できそうです。しかし,現実にはメモリ・ブロックは10 ビット幅の構成では使用できないので,16 ビット幅の構成を取らざるを得ません。このため,

**表**3 **ブロック** RAM **の構成例** 

| メモリ構成        | コメント         |
|--------------|--------------|
| 16K × 1 ビット  |              |
| 8K × 2 ビット   |              |
| 4K × 4 ビット   |              |
| 2K × 8ビット    | パリティなし       |
| 2K × 9 ビット   | パリティあ((1ビット) |
| 1K × 16 ビット  | パリティなし       |
| 1K × 18 ビット  | パリティあ((2ビット) |
| 512 × 32 ビット | パリティなし       |
| 512 × 36 ビット | パリティあ((4ビット) |
| 256 × 72 ビット | シングル・ポートのみ   |



図12 乗算器ブロックの構造

18 ビット $\times$  18 ビット以下の乗算を実行できる.入出力段にそれぞれオプションのレジスタ( AREG , BREF , PREG )が追加されている.

1000 ワード×16 ビット構成のメモリ・ブロックを2 個使用することになります.設計の初期段階でリソースを見積もる場合には,こういった制約に注意する必要があります.また,メモリ・ブロックを大きな LUT として使用することもできます.

## ● 乗算器ブロック

Spartan-3Eでは,18ビット×18ビット以下の乗算を実行できるブロックを持ちます(図12).乗算器ブロックは,メモリ・ブロックと同じ数だけ搭載されています.論理ブロックを使用して乗算器を実現するよりも,性能と消費電力の両面で有利になり,さらに論理ブロック数を削減できるので,積極的に乗算器を使うように心掛けましょう.

Spartan-3の乗算器と比べて,新たにレジスタ(AREG,

BREF, PREG)が追加になりました.これらのレジスタは,主に乗算性能を向上させたい時やCLBレジスタを節約するために使用します.

## ● コンフィグレーション回路

Spartan-3E では , 表4に示すコンフィグレーション・モードを持ちます .

この中で,Xilinx社の純正ROMを使用してコンフィグレーションを行う各モードと,ROMを使用しないJTAGモードは,Spartan-3でもサポートされています.さらに,汎用フラッシュ・メモリを使用して直接コンフィグレーションするモードをサポートしているのがSpartan-3Eの特徴です.ほかの目的で,基板上にフラッシュ・メモリを搭載する必要があるのであれば,コンフィグレーション用

表4 Spartan-3E <mark>のコンフィ</mark> グレーション・モード

| Xilinx 社の純正ROM を使用する |                                              |  |  |  |
|----------------------|----------------------------------------------|--|--|--|
| Master Serialモード     | FPGA がマスタとなり、ROM にクロックを供給する.                 |  |  |  |
|                      | ROM からは 1 ビット幅のコンフィグレーション・データを受け取る .         |  |  |  |
| Slave Serial モード     | FPGA はスレーブとなり、外部からクロックをもらう.                  |  |  |  |
|                      | ROM からは 1 ビット幅のコンフィグレーション・データを受け取る .         |  |  |  |
| Slave Parallel モード   | FPGA はスレーブとなり、外部からクロックをもらう.                  |  |  |  |
|                      | ROM からは 8 ビット幅のコンフィグレーション・データを受け取る .         |  |  |  |
| 汎用フラッシュ・メモリを使用する     |                                              |  |  |  |
| SPI モード              | 汎用シリアル・フラッシュ・メモリから直接,コンフィグレーション・データを受け取る.    |  |  |  |
| BPIモード               | 汎用パラレルNOR型フラッシュ・メモリから直接,コンフィグレーション・データを受け取る. |  |  |  |
| ROM を使用しない           |                                              |  |  |  |
| JTAGモード              | パソコンからJTAGピンを経由してコンフィグレーション・データを受け取る.        |  |  |  |



図13 Master Serial Mode と JTAG Mode が使用でき るコンフィグレーション 制御回路

Platform Cable USB などのコンフィグレーション用ケーブルを用いてFPGAやコンフィグレーションROMにコンフィグレーション・データを書き込む.

# 総力特集

# 付属FPGA基板を使った 回路設計チュートリアル Part3

ROM に割かれる基板スペースを削減できるでしょう.

FPGA のコンフィグレーション制御回路は, FPGA ユーザが自由に制御できる部分ではないので,詳細は省略します.ここでは,付属 FPGA 基板でサポートされている「Master Serial Mode」と「JTAG Mode」についてだけ簡単に動作を説明します. 図 13に Master Serial Modeと JTAG Modeが使用できるコンフィグレーション制御回路の例を示します.

## (1) Master Serial Mode

Master Serial Mode は,FPGA のコンフィグレーション・モードとしては一番基本的なモードです.このモードは FPGA から ROM ヘクロックを与えて,ROM からシリアル・データを取り込む方法です.

以下に大まかなコンフィグレーションのシーケンスを示 します.

各電源電圧が要求レベルに達すると、FPGA内部のパワーONリセットが解除されます.この時、PROG\_Bピンを"L"にドライブすることによって、コンフィグレーション処理を待たせることができます.初期化が終了すると、FPGAはINITピンを開放し、M[2:0]ピンで設定されているコンフィグレーション・モードを読みに行きます.Master Serial Modeであることが確認されるとCCLKの出力を開始し、ROMはCCLKに同期したデータをFPGAに送信します.コンフィグレーション・データを正常に取得すると、FPGAはスタートアップ・シーケンスに移行します.スタートアップ・シーケンスは八つのフェーズに分かれています.通常、スタートアップ・シーケンスのフェーズ4で開放されるDONEピンを見て、正常にコンフィグレーションが完了したかどうかを判断します(DONEピン

はオープン・ドレイン出力のため,開放されると外部プルアップによって"H"を示す).

### (2) JTAG Mode

基板上に実装されたROMにコンフィグレーション・データを書き込むときにはJTAGインターフェースが使用されます.またFPGAもJTAGインターフェースを持っていて,パソコンから直接FPGAへのコンフィグレーションを行うことができます.コンフィグレーション・データの受信方法はほかのモードと異なりますが,FPGA内部のコンフィグレーション・シーケンスは前述の Master Serial Mode と変わりません.

なお,パソコンと基板上のJTAGコネクタとの接続には, Platform Cable USBなどのコンフィグレーション用ケー ブルを用います.

#### 参考・引用\*文献

- (1)Xilinx; Spartan-3E FPGA Family: Complete Data Sheet, March 16, 2007.
- (2)Xilinx; Spartan-3 Generation FPGA User Guide, April2, 2007.

さかい・ひろあき こくぼ・けんじ アヴネット ジャパン(株)

## <筆者プロフィール> --

**酒井浩昭**.2002年アヴネット ジャパン入社.現在エンジニアリング部所属.

**小久保賢二**. 1999 年アヴネット ジャパン入社. 現在エンジニアリング部所属.

Design Wave Magazine 2007年5月号増刊

好評発売中



# FPGA/PLD 設計スタートアップ 2007/2008 年版

Design Wave Magazine 編集部 編 B5 変型判 256 ページ DVD-ROM 付き 定価 2,100 円(税込)

FPGA やPLD などのプログラマブル・デバイスをターゲットにした設計をこれから始める方のための入門書です.「Quartus II」や「ISE」などのFPGA/PLD 開発ツールの使い方を具体的な手順を示しながら説明しています.

また,「Cyclone/II/III」,「MAX II」「Spartan-3/E/A/AN」などのアーキテクチャを解説します.HDL による論理回路の設計例,周辺回路の設計法などの解説がありますので,FPGA/PLDを活用していくにあたってのハンドブックにもなります.シリアル通信回路,LCD表示回路など,数多くのサンプル回路を紹介しています.付属 DVD-ROM には,「Quartus II Web Edition」と「ISE WebPACK」のほか,記事に関連する設計データを収録しています.

**CQ出版社** 〒170-8461 東京都豊島区巣鴨1-14-2 販売部 ☎ (03)5395-2141 振替 00100-7-10665